- 
                Notifications
    You must be signed in to change notification settings 
- Fork 10
fix #33 #43
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix #33 #43
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pull Request Overview
This PR implements an initial version of circular relationship detection for batch hierarchies in the stored procedure. It adds a recursive CTE to traverse the DAG, performs cycle detection by verifying that the new relationship does not introduce a cycle, and logs an error when a cycle is found.
| DROP TABLE IF EXISTS #DagViolation; | ||
| GOTO EndOfProcedureFailure; | 
    
      
    
      Copilot
AI
    
    
    
      May 20, 2025 
    
  
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Using GOTO for error handling can reduce the clarity and maintainability of the procedure. Consider refactoring the error handling to rely solely on the TRY/CATCH structure instead of branching with GOTO.
| DROP TABLE IF EXISTS #DagViolation; | |
| GOTO EndOfProcedureFailure; | |
| SET @SuccessIndicator = 'N'; | |
| DROP TABLE IF EXISTS #DagViolation; | |
| THROW 50001, @LogMessage, 1; | 
| IF @CheckDag = 'Y' | ||
| BEGIN | ||
| PRINT('There should be some clever SQL added here to warn of circular relations...') | ||
| ;WITH Ancestors AS ( | 
    
      
    
      Copilot
AI
    
    
    
      May 20, 2025 
    
  
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It would be helpful to include a comment explaining the recursive CTE's logic and how it retrieves the chain of ancestors for cycle detection.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks Stefan!
add initial version of circular relationship testing for testing